import java.util.ArrayList;

/**
 * Created with IntelliJ IDEA.
 * Description:输入一个升序数组 array 和一个数字S，在数组中查找两个数，
 * 使得他们的和正好是S，如果有多对数字的和等于S，返回任意一组即可，如果无法找出这样的数字，返回一个空数组即可。
 * User: wangxin
 * Date: 2025-03-09
 * Time: 21:40
 */
public class Test2 {
    public ArrayList<Integer> FindNumbersWithSum(int [] array, int sum) {
        ArrayList<Integer> res = new ArrayList<>();
        if(array.length == 0||sum <= 0){
            return res;
        }
        int n = array.length;
        int left = 0;
        int right = n-1;
        while(left < n && right >= 0 && left < right){
            if(array[left] + array[right] == sum){
                res.add(array[left]);
                res.add(array[right]);
                break;
            }else if(array[left] + array[right] > sum){
                right--;
            }else{
                left++;
            }
        }
        return res;
    }
}
